// 权限拦截 路由守卫
import router from '@/router'
// 引入store
import store from '@/store'
import NProgress from 'nprogress' // 引入一份进度条插件
import 'nprogress/nprogress.css'  // 引入进度条样式

const whiteList = ['/login', '/404'] // 定义白名单  所有不受权限控制的页面
router.beforeEach(async(to, from, next) => {
  NProgress.start() // 开启进度条
  if (store.getters.token) {
    // 有token 在判断是不是在登录页 是就跳转到主页
    if (to.path === '/login') {
      router.push('/')
    } else {
      if (!store.getters.userId) {
        // 没有信息就要获取信息
        await store.dispatch('user/getUserInfo')
      }
      next()
    }
  } else {
    // 没有token 又在白名单里
    if (whiteList.indexOf(to.path) > -1) {
      next()
    } else {
      router.push('/login')
    }
  }
  NProgress.done() // 手动强制关闭一次  为了解决 手动切换地址时  进度条的不关闭的问题
})
router.afterEach(function() {
  NProgress.done() // 也同样关闭精度条
})
